翻訳と辞書
Words near each other
・ Backdrop Peak
・ Backdrop Ridge
・ Backe
・ Backe (surname)
・ Backe, backe Kuchen
・ Backe, Carmarthenshire
・ Backe, Sweden
・ Backen
・ Backen Church
・ Backer
・ Backer Aloenouvo
・ Backer Islands
・ Backergunge District
・ Back-chaining
・ Back-end database
Back-face culling
・ Back-fire
・ Back-formation
・ Back-Fusion
・ Back-illuminated sensor
・ Back-of-the-envelope calculation
・ Back-off pattern
・ Back-On
・ Back-pass rule
・ Back-rank checkmate
・ Back-reaction
・ Back-released velar click
・ Back-Room Boy
・ Back-seat driver
・ Back-side bus


Dictionary Lists
翻訳と辞書 辞書検索 [ 開発暫定版 ]
スポンサード リンク

Back-face culling : ウィキペディア英語版
Back-face culling

In computer graphics, back-face culling determines whether a polygon of a graphical object is visible. It is a step in the graphical pipeline that tests whether the points in the polygon appear in clockwise or counter-clockwise order when projected onto the screen. If the user has specified that front-facing polygons have a clockwise winding, but the polygon projected on the screen has a counter-clockwise winding then it has been rotated to face away from the camera and will not be drawn.
The process makes rendering objects quicker and more efficient by reducing the number of polygons for the program to draw. For example, in a city street scene, there is generally no need to draw the polygons on the sides of the buildings facing away from the camera; they are completely occluded by the sides facing the camera.
In general back-face culling can be assumed to produce no visible artifact in a rendered scene if it contains only closed and opaque geometry. In scenes containing transparent polygons, rear
facing polygons may become visible through the process of alpha composition. In wire-frame rendering, back-face culling can be used to partially address problem of hidden line removal, but only for closed convex geometry.
A related technique is clipping, which determines whether polygons are within the camera's field of view at all.
Another similar technique is Z-culling, also known as occlusion culling, which attempts to skip the drawing of polygons which are covered from the viewpoint by other visible polygons.
== Implementation ==

One method of implementing back-face culling is by discarding all triangles where the dot product of their surface normal and the camera-to-triangle vector is greater than or equal to zero
: \left( V_ - P\right) \cdot N \ge 0
where is the view point, is the first vertex of a triangle and is its normal, defined as a cross product of two vectors representing sides of the triangle adjacent to
: N = \left( V_ - V_\right) \times \left( V_ - V_\right)
Since cross product is non-commutative, defining the normal in terms of cross product allows to specify normal direction relative to triangle surface using vertex order(winding):
:\left( V_ - V_\right) \times \left( V_ - V_\right) = - \left( V_ - V_\right) \times \left( V_ - V_\right)
If points are already in view space, can be assumed to be , the origin.
: -V_ \cdot N \ge 0
It is also possible to use this method in projection space by representing above inequality as determinant of a matrix and applying projection matrix to it.〔David H. Eberly (2006). ''3D Game Engine Design: A Practical Approach to Real-Time Computer Graphics'', p. 69. Morgan Kaufmann Publishers, United States. ISBN 0122290631.〕
Another method exists based on reflection parity, which is more appropriate for two dimensions where surface normal cannot be computed (also known as CCW check).
Let a unit triangle in two dimensions (homogeneous coordinates) be defined as
:U_ = \begin 0 \\ 0 \\ 1 \end, U_ = \begin 1 \\ 0 \\ 1 \end, U_ = \begin 0 \\ 1 \\ 1 \end
Then for some other triangle, also in two dimensions,
:V_ = \begin x_ \\ y_ \\ 1 \end, V_ = \begin x_ \\ y_ \\ 1 \end, V_ = \begin x_ \\ y_ \\ 1 \end
define a matrix that transforms the unit triangle into it
:M = \begin x_-x_ & x_-x_ & x_ \\ y_-y_ & y_-y_ & y_ \\ 0 & 0 & 1 \end
so that
:MU_=V_
:MU_=V_
:MU_=V_
Discard the triangle if matrix contained odd number of reflections (facing the opposite way of unit triangle)
:\left| M \right| < 0
Unit triangle is used as a reference and transformation is used as a trace to tell if vertex order is different between two triangles. The only way vertex order can change in two dimensions is by reflection. Reflection is an example of involutory function (with respect to vertex order), even number of reflections will leave triangle facing the same side, as if no reflections were applied at all. An odd number of reflections will leave triangle facing the other side, as if exactly after one reflection. Transformations containing an odd number of reflections always have negative scaling factor, likewise scaling factor is positive if there are no reflections or even number of them. Scaling factor of a transformation is computed by determinant of its matrix.

抄文引用元・出典: フリー百科事典『 ウィキペディア(Wikipedia)
ウィキペディアで「Back-face culling」の詳細全文を読む



スポンサード リンク
翻訳と辞書 : 翻訳のためのインターネットリソース

Copyright(C) kotoba.ne.jp 1997-2016. All Rights Reserved.